FE_DIVBYZERO (C++11)

int

极错误

这个宏展开成一个 int 型的值,用来表示触发 极错误 时的 浮点异常

极错误 出现在操作结果渐进无限时,例如,被 0 除,或者 log(0.0)。

它被定义为 2 的整数次方,允许和多个 浮点异常 组合(使用按位 OR 操作:| )成为单个值:

宏值 描述
FE_DIVBYZERO 极错误:被 0 除,或一些其他渐进无限的结果(从有限的参数)。
FE_INEXACT 不精确:结果不准确。
FE_INVALID 作用域错误:至少一个参数是函数没有定义的值。
FE_OVERFLOW 上溢错误:结果太大了,超出了返回值类型能表示的数量级。
FE_UNDERFLOW 下一错误:结果太小了,超出了返回值类型能表示的数量级。
FE_ALL_EXCEPT 所有异常(选择实现支持的所有异常)

特定的库实现可能会支持附加的 浮点异常 值(它们对应的宏同样以 FE_ 开头的宏)。

C99

库可能定义在 <fenv.h>,仅仅支持上面这些宏值(其他可能没有被定义)。
FE_DIVBYZERO 总是被定义,如果 math_errhandlingMATH_ERREXCEPT 集合。

C++11

至少上面所有的宏值都定义在 <fenv.h> 中(即使实现不支持)。

另请参见

宏名 描述
FE_INEXACT 不精确的结果异常 ()
FE_INVALID 无效参数异常 ()
FE_OVERFLOW 向上溢出错误异常 ()
FE_UNDERFLOW 向下溢出错误异常 ()
FE_ALL_EXCEPT 所有异常 ()